/**
 * @author Roger Wu v1.0
 * @author ZhangHuihua@msn.com 2011-4-1
 */
(function($){
    $.fn.jTable = function(options){
        return this.each(function(){
            var $table = $(this), nowrapTD = $table.attr("nowrapTD");
            var tlength = $table.width();
            var aStyles = [];
            var $tc = $table.parent().addClass("j-resizeGrid"); // table parent container
            var oldThs = $table.find("thead>tr:last-child").find("th");

            for(var i = 0, l = oldThs.length; i < l; i++) {
                var $th = $(oldThs[i]);
                var style = [], width = $th.innerWidth() - (100 * $th.innerWidth() / tlength)-2;
                style[0] = parseInt(width);
                style[1] = $th.attr("align");
                aStyles[aStyles.length] = style;
            }
            $(this).wrap("<div class=\"grid\"></div>");
            var $grid = $table.parent().html($table.html());
            var thead = $grid.find("thead");
            thead.wrap("<div class=\"gridHeader\"><div class=\"gridThead\"><table style=\"width:" + (tlength - 20) + "px;\"></table></div></div>");
            var lastH = $(">tr:last-child", thead);
            var ths = $(">th", lastH);
            $("th",thead).each(function(){
                var $th = $(this);
                $th.html("<div class=\"gridCol\" title=\""+$th.text()+"\">"+ $th.html() +"</div>");
            });

            ths.each(function(i){
                var $th = $(this), style = aStyles[i];
                $th.addClass(style[1]).removeAttr("align").removeAttr("width").width(style[0]);
            }).filter("[orderField]").orderBy({
                targetType: $table.attr("targetType"),
                rel: $table.attr("rel"),
                asc: $table.attr("asc") || "asc",
                desc: $table.attr("desc") || "desc",
                orderField: $table.attr("orderField"),
                orderType: $table.attr("orderType")
            });

            var tbody = $grid.find(">tbody");
            tbody.wrap("<div class=\"gridScroller\" layoutH style=\"width:" + $tc.width() + "px;\"><div class=\"gridTbody\"><table style=\"width:" + (tlength - 20) + "px;\"></table></div></div>");
            var ftr = $(">tr:first-child", tbody);
            var $trs = tbody.find(">tr");

            $trs.each(function(){
                var $tr = $(this);
                var $ftds = $(">td", this);

                for (var i=0; i < $ftds.length; i++) {
                    var $ftd = $($ftds[i]);
                    if (nowrapTD != "false") {
                        $ftd.html("<div>" + $ftd.html() + "</div>");
                    }
                    if (i < aStyles.length) {
                        $ftd.addClass(aStyles[i][1]);
                    }
                }
                $tr.click(function(){
                    tbody.find(">tr.selected").removeClass("selected");
                    $tr.addClass("selected");
                    var sTarget = $tr.attr("target");
                    if (sTarget) {
                        if ($("#"+sTarget, $grid).length == 0) {
                            $grid.prepend("<input id=\""+sTarget+"\" type=\"hidden\" />");
                        }
                        $("#"+sTarget, $grid).val($tr.attr("rel"));
                    }
                });
                if ($(".edit", $tr).length) {
                    $tr.dblclick(function() {
                        $(".edit", $tr).eq(0).click();
                    });
                } else if ($(".icon-edit", ( !$.pdialog.getCurrent() ) ? navTab.getCurrentPanel(): $.pdialog.getCurrent()).length ) {
                    $tr.dblclick(function() {
                        $(".icon-edit", ( !$.pdialog.getCurrent() ) ? navTab.getCurrentPanel(): $.pdialog.getCurrent()).eq(0).parent().click();
                    });
                }
            });

            $(">td",ftr).each(function(i){
                if (i < aStyles.length) $(this).width(aStyles[i][0]);
            });
            $grid.append("<div class=\"resizeMarker\" style=\"height:300px; left:57px;display:none;\"></div><div class=\"resizeProxy\" style=\"height:300px; left:377px;display:none;\"></div>");

            var scroller = $(".gridScroller", $grid);
            scroller.scroll(function(event){
                var header = $(".gridThead", $grid);
                if(scroller.scrollLeft() > 0){
                    header.css("position", "relative");
                    var scroll = scroller.scrollLeft();
                    header.css("left", scroller.cssv("left") - scroll);
                }
                if(scroller.scrollLeft() == 0) {
                    header.css("position", "relative");
                    header.css("left", "0px");
                }
                return false;
            });


            $(">tr", thead).each(function(){

                $(">th", this).each(function(i){
                    var th = this, $th = $(this);
                    $th.mouseover(function(event){
                        var offset = $.jTableTool.getOffset(th, event).offsetX;
                        if($th.outerWidth() - offset < 5) {
                            $th.css("cursor", "col-resize").mousedown(function(event){
                                $(".resizeProxy", $grid).show().css({
                                    left: $.jTableTool.getRight(th)- $(".gridScroller", $grid).scrollLeft(),
                                    top:$.jTableTool.getTop(th),
                                    height:$.jTableTool.getHeight(th,$grid),
                                    cursor:"col-resize"
                                });
                                $(".resizeMarker", $grid).show().css({
                                        left: $.jTableTool.getLeft(th) + 1 - $(".gridScroller", $grid).scrollLeft(),
                                        top: $.jTableTool.getTop(th),
                                        height:$.jTableTool.getHeight(th,$grid)
                                });
                                $(".resizeProxy", $grid).jDrag($.extend(options, {scop:true, cellMinW:20, relObj:$(".resizeMarker", $grid)[0],
                                        move: "horizontal",
                                        event:event,
                                        stop: function(){
                                            var pleft = $(".resizeProxy", $grid).position().left;
                                            var mleft = $(".resizeMarker", $grid).position().left;
                                            var move = pleft - mleft - $th.outerWidth() -9;

                                            var cols = $.jTableTool.getColspan($th);
                                            var cellNum = $.jTableTool.getCellNum($th);
                                            var oldW = $th.width(), newW = $th.width() + move;
                                            var $dcell = $(">td", ftr).eq(cellNum - 1);

                                            $th.width(newW + "px");
                                            $dcell.width(newW+"px");

                                            var $table1 = $(thead).parent();
                                            $table1.width(($table1.width() - oldW + newW)+"px");
                                            var $table2 = $(tbody).parent();
                                            $table2.width(($table2.width() - oldW + newW)+"px");

                                            $(".resizeMarker,.resizeProxy", $grid).hide();
                                        }
                                    })
                                );
                            });
                        } else {
                            $th.css("cursor", $th.attr("orderField") ? "pointer" : "default");
                            $th.off("mousedown");
                        }
                        return false;
                    });
                });
            });

            function _resizeGrid(){
                $("div.j-resizeGrid").each(function(){
                    var width = $(this).innerWidth();
                    if (width){
                        $("div.gridScroller", this).width(width+"px");
                        if(width -20 > $("div.gridHeader>.gridThead>table", this).width()) {
                            $("div.gridHeader>.gridThead>table", this).width((width - 20 )+"px");
                            $("div.gridScroller>.gridTbody>table", this).width((width - 20 )+"px");
                        }
                    }
                });
            }
            $(window).off(JUI.eventType.resizeGrid).on("resizeGrid", null, null, _resizeGrid);
        });
    };


    $.jTableTool = {
        getLeft:function(obj) {
            var width = 0;
            $(obj).prevAll().each(function(){
                width += $(this).outerWidth();
            });
            return width - 1;
        },
        getRight:function(obj) {
            var width = 0;
            $(obj).prevAll().addBack().each(function(){
                width += $(this).outerWidth();
            });
            return width - 1;
        },
        getTop:function(obj) {
            var height = 0;
            $(obj).parent().prevAll().each(function(){
                height += $(this).outerHeight();
            });
            return height;
        },
        getHeight:function(obj, parent) {
            var height = 0;
            var head = $(obj).parent();
            head.nextAll().addBack().each(function(){
                height += $(this).outerHeight();
            });
            $(".gridTbody", parent).children().each(function(){
                height += $(this).outerHeight();
            });
            return height;
        },
        getCellNum:function(obj) {
            return $(obj).prevAll().addBack().length;
        },
        getColspan:function(obj) {
            return $(obj).attr("colspan") || 1;
        },
        getStart:function(obj) {
            var start = 1;
            $(obj).prevAll().each(function(){
                start += parseInt($(this).attr("colspan") || 1);
            });
            return start;
        },
        getPageCoord:function(element){
            var coord = {x: 0, y: 0};
            while (element){
                coord.x += element.offsetLeft;
                coord.y += element.offsetTop;
                element = element.offsetParent;
            }
            return coord;
        },
        getOffset:function(obj, evt){
            if(/msie/.test(navigator.userAgent.toLowerCase())) {
                var objset = $(obj).offset();
                var evtset = {
                    offsetX:evt.pageX || evt.screenX,
                    offsetY:evt.pageY || evt.screenY
                };
                var offset ={
                    offsetX: evtset.offsetX - objset.left,
                    offsetY: evtset.offsetY - objset.top
                };
                return offset;
            }
            var target = evt.target;
            if (target.offsetLeft == undefined){
                target = target.parentNode;
            }
            var pageCoord = $.jTableTool.getPageCoord(target);
            var eventCoord ={
                x: window.pageXOffset + evt.clientX,
                y: window.pageYOffset + evt.clientY
            };
            var offset ={
                offsetX: eventCoord.x - pageCoord.x,
                offsetY: eventCoord.y - pageCoord.y
            };
            return offset;
        }
    };
})(jQuery);
/**
 * cssTable Plugins
 *
 * @author ZhangHuihua@msn.com
 */
( function($) {
    $.fn.extend({
        cssTable: function(options) {
            return this.each(function() {
                var $this = $(this);
                var $trs = $this.find("tbody>tr");
                var $grid = $this.parent(); // table

                $trs.each(function(index) {
                    var $tr = $(this);
                    $tr.click(function() {
                        $this.find("tbody>tr.selected").removeClass("selected");
                        $tr.addClass("selected");
                        var sTarget = $tr.attr("target");
                        if (sTarget ) {
                            if ($("#" + sTarget, $grid).length == 0 ) {
                                $grid.prepend("<input id=\"" + sTarget + "\" type=\"hidden\"/>");
                            }
                            $("#" + sTarget, $grid).val($tr.attr("rel"));
                        }
                    });
                    if ($(".edit", $tr).length) {
                        $tr.dblclick(function() {
                            $(".edit", $tr).eq(0).click();
                        });
                    } else if ($(".panelBar .icon-edit", ( !$.pdialog.getCurrent() ) ? navTab.getCurrentPanel(): $.pdialog.getCurrent()).length ) {
                        $tr.dblclick(function() {
                            $(".panelBar .icon-edit", ( !$.pdialog.getCurrent() ) ? navTab.getCurrentPanel(): $.pdialog.getCurrent()).eq(0).parent().click();
                        });
                    }
                });
                $this.find("thead [orderField]").orderBy({
                    targetType: $this.attr("targetType"), rel: $this.attr("rel"), asc: $this.attr("asc") || "asc", desc: $this.attr("desc") || "desc" , orderField: $this.attr("orderField"), orderType: $this.attr("orderType")
                });
            });
        }
    });
} )(jQuery);

/**
 * @author ZhangHuihua@msn.com
 * @param {Object}
 *            opts Several options
 */
( function($) {
    $.fn.extend({
        orderBy: function(options) {
            var op = $.extend({
                targetType: "navTab", rel: "", asc: "asc", desc: "desc" , orderType : "", orderField : ""
            }, options);
            return this.each(function() {
                var $this = $(this).click(function() {
                    var orderField = $this.attr("orderField");
                    var orderDirection = $this.hasClass(op.asc) ? op.desc: op.asc;
                    dwzPageBreak({
                        targetType: op.targetType, rel: op.rel, data: {
                            orderField: orderField, orderDirection: orderDirection
                        }
                    });
                });
                if(op.orderField == $this.attr("orderField")) {
                    if(op.asc == op.orderType) {
                        $this.addClass(op.asc);
                    } else if(op.desc == op.orderType) {
                        $this.addClass(op.desc);
                    } else {
                        $this.addClass("order");
                    }
                } else {
                    $this.addClass("order");
                }
            });
        }
    });
} )(jQuery);